<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~     http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  -->

@if (parameterContextListingState$ | async; as parameterContextListingState) {
    @if (isInitialLoading(parameterContextListingState)) {
        <div>
            <ngx-skeleton-loader count="3"></ngx-skeleton-loader>
        </div>
    } @else {
        <div class="flex flex-col h-full gap-y-2">
            @if (currentUser$ | async; as currentUser) {
                @if (currentUser.parameterContextPermissions.canWrite) {
                    <div class="flex justify-end">
                        <button mat-icon-button class="primary-icon-button" (click)="openNewParameterContextDialog()">
                            <i class="fa fa-plus"></i>
                        </button>
                    </div>
                }
                <div class="flex-1">
                    <parameter-context-table
                        [parameterContexts]="parameterContextListingState.parameterContexts"
                        [selectedParameterContextId]="selectedParameterContextId$ | async"
                        [currentUser]="currentUser"
                        [flowConfiguration]="(flowConfiguration$ | async)!"
                        (selectParameterContext)="selectParameterContext($event)"
                        (editParameterContext)="editParameterContext($event)"
                        (deleteParameterContext)="deleteParameterContext($event)"
                        (manageAccessPolicies)="navigateToManageComponentPolicies($event)"></parameter-context-table>
                </div>
                <div class="flex justify-between">
                    <div class="text-sm flex items-center gap-x-2">
                        <button mat-icon-button class="primary-icon-button" (click)="refreshParameterContextListing()">
                            <i
                                class="fa fa-refresh"
                                [class.fa-spin]="parameterContextListingState.status === 'loading'"></i>
                        </button>
                        <div>Last updated:</div>
                        <div class="tertiary-color font-medium">
                            {{ parameterContextListingState.loadedTimestamp }}
                        </div>
                    </div>
                </div>
            }
        </div>
    }
}
